@@ -11,7 +11,7 @@ module Agents |
||
11 | 11 |
description <<-MD |
12 | 12 |
The Shell Command Agent will execute commands on your local system, returning the output. |
13 | 13 |
|
14 |
- `command` specifies the command to be executed, and `path` will tell ShellCommandAgent in what directory to run this command. |
|
14 |
+ `command` specifies the command (either a shell command line string or an array of command line arguments) to be executed, and `path` will tell ShellCommandAgent in what directory to run this command. |
|
15 | 15 |
|
16 | 16 |
`expected_update_period_in_days` is used to determine if the Agent is working. |
17 | 17 |
|
@@ -50,6 +50,10 @@ module Agents |
||
50 | 50 |
errors.add(:base, "The path, command, and expected_update_period_in_days fields are all required.") |
51 | 51 |
end |
52 | 52 |
|
53 |
+ unless Array(options['command']).all? { |o| o.is_a?(String) } |
|
54 |
+ errors.add(:base, "command must be a shell command line string or an array of command line arguments.") |
|
55 |
+ end |
|
56 |
+ |
|
53 | 57 |
unless File.directory?(options['path']) |
54 | 58 |
errors.add(:base, "#{options['path']} is not a real directory.") |
55 | 59 |
end |
@@ -92,7 +96,7 @@ module Agents |
||
92 | 96 |
rout, wout = IO.pipe |
93 | 97 |
rerr, werr = IO.pipe |
94 | 98 |
|
95 |
- pid = spawn(command, chdir: path, out: wout, err: werr) |
|
99 |
+ pid = spawn(*command, chdir: path, out: wout, err: werr) |
|
96 | 100 |
|
97 | 101 |
wout.close |
98 | 102 |
werr.close |
@@ -5,15 +5,25 @@ describe Agents::ShellCommandAgent do |
||
5 | 5 |
@valid_path = Dir.pwd |
6 | 6 |
|
7 | 7 |
@valid_params = { |
8 |
- :path => @valid_path, |
|
9 |
- :command => "pwd", |
|
10 |
- :expected_update_period_in_days => "1", |
|
11 |
- } |
|
8 |
+ path: @valid_path, |
|
9 |
+ command: 'pwd', |
|
10 |
+ expected_update_period_in_days: '1', |
|
11 |
+ } |
|
12 |
+ |
|
13 |
+ @valid_params2 = { |
|
14 |
+ path: @valid_path, |
|
15 |
+ command: [RbConfig.ruby, '-e', 'puts "hello, world."; STDERR.puts "warning!"'], |
|
16 |
+ expected_update_period_in_days: '1', |
|
17 |
+ } |
|
12 | 18 |
|
13 |
- @checker = Agents::ShellCommandAgent.new(:name => "somename", :options => @valid_params) |
|
19 |
+ @checker = Agents::ShellCommandAgent.new(name: 'somename', options: @valid_params) |
|
14 | 20 |
@checker.user = users(:jane) |
15 | 21 |
@checker.save! |
16 | 22 |
|
23 |
+ @checker2 = Agents::ShellCommandAgent.new(name: 'somename2', options: @valid_params2) |
|
24 |
+ @checker2.user = users(:jane) |
|
25 |
+ @checker2.save! |
|
26 |
+ |
|
17 | 27 |
@event = Event.new |
18 | 28 |
@event.agent = agents(:jane_weather_agent) |
19 | 29 |
@event.payload = { |
@@ -27,6 +37,7 @@ describe Agents::ShellCommandAgent do |
||
27 | 37 |
describe "validation" do |
28 | 38 |
before do |
29 | 39 |
expect(@checker).to be_valid |
40 |
+ expect(@checker2).to be_valid |
|
30 | 41 |
end |
31 | 42 |
|
32 | 43 |
it "should validate presence of necessary fields" do |
@@ -70,6 +81,14 @@ describe Agents::ShellCommandAgent do |
||
70 | 81 |
expect(Event.last.payload[:output]).to eq("fake pwd output") |
71 | 82 |
end |
72 | 83 |
|
84 |
+ it "should create an event when checking (unstubbed)" do |
|
85 |
+ expect { @checker2.check }.to change { Event.count }.by(1) |
|
86 |
+ expect(Event.last.payload[:path]).to eq(@valid_path) |
|
87 |
+ expect(Event.last.payload[:command]).to eq([RbConfig.ruby, '-e', 'puts "hello, world."; STDERR.puts "warning!"']) |
|
88 |
+ expect(Event.last.payload[:output]).to eq('hello, world.') |
|
89 |
+ expect(Event.last.payload[:errors]).to eq('warning!') |
|
90 |
+ end |
|
91 |
+ |
|
73 | 92 |
it "does not run when should_run? is false" do |
74 | 93 |
stub(Agents::ShellCommandAgent).should_run? { false } |
75 | 94 |
expect { @checker.check }.not_to change { Event.count } |